#include <bits/stdc++.h>
using namespace std;
int dp[1005];
int n,m,w,v;
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    { 
	    cin >> v >> w;
        for(int j=1;j<=m;j++)
        {
            if(j>=v)
            {
        	    dp[j]=max(dp[j-v]+w,dp[j]);
		    }
        }
    }
    cout << dp[m] << endl;
    return 0;
}
